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O ! Abstract 

We consider the problem of orienting the edges of the n-diniensional hypercube so only two 
^ I different in-degrees a and b occur. We show that this can be done, for two specified in-degrees, 

if and only if an obvious necessary condition holds. Namely, there exist non-negative integers 
■"nI" I s and t so that s + 1 = 2" and as + bt = n2"~^. This is connected to a question arising from 

constructing a strategy for a "hat puzzle." 
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1 Introduction 

For our purposes, the n-dimensional hypercube, or n-cube, is a graph whose vertices are binary 
n-tuples, with edges joining two vertices that differ in exactly one coordinate, i.e., in the language 
of error-correcting codes, they have Hamming distance one. An orientation of the n-cube specifies 
a head and tail for each edge, and the in-degree of a vertex is the number of incoming edges at 



(~^ ■ that vertex. If an orientation has only two different in-degrees, say s vertices of in-degree a and t 

^D . vertices of in-degree 6, then there are 



vertices and 

as + bt = n2''-^ 

edges (by counting edge heads). Our main result, proved by modifying suitable Hamming codes, is 
that these obvious necessary conditions for the existence of an orientation with in-degrees a and h 
— non-negative integers s and t satisfying these equations — is in fact sufficient. 

This question was implicitly raised by H. Iwasawa [3] in a different context — finding strategies 
for specific hat guessing games that he introduced. There are many puzzles involving hats or "hat 
guessing games". Most of them have the following set-up: A team of n players has an initial 



*Center for Communications Research, La JoUa, CA 92121 (buhler@ccrwest.org) 

^Department of Mathematics, UCLA, Los Angeles, CA 90095 (butler@math.ucla.edu). 
This work was done with support of an NSF Mathematical Sciences Postdoctoral Fellowship. 

"^Department of Computer Science and Engineering, University of California, San Diego, La Jolla, CA 92093 
(graham@ucsd.edu). 

''Department of Mathematics, University of California, San Diego, La Jolla, CA 92093 (etressle@math.ucsd.edu). 



strategy session where they decide on their joint strategy. Later, a referee (or adversary) places 
hats colored either or 1 on the players' heads, and the players can see all hat colors except that 
of their own hat. Shortly thereafter, the players must simultaneously guess their hat color, with no 
communication between the players, or knowledge of other guesses, allowed. A game is specified 
by the goal that the players try to achieve; if they are successful they each win one million dollars. 
Examples include: (1) the hat placement is uniformly random and the players want to maximize 
the probability that all guesses are correct, (2) the players want to guarantee that at least [ra/2j 
guesses are correct, or (3) the players want to guarantee that either all players are right or all are 
wrong. Iwasawa generalizes variant (3) by asking that either exactly a players are correct, or b 
players are correct. 

At the initial strategy session the first thing that the players might do is to number themselves 
from 1 to n. A placement of the n hats can then be identified with a binary n-tuple, which we 
will think of as a vertex of the n-cube. When a player sees all hat colors but her own, she knows 
that the placement is one of the two (adjacent) vertices of the n-cube. A strategy is a rule that 
tells each player which vertex to choose. Thus a (deterministic) strategy, to be agreed on at the 
team's initial strategy session is an orientation of the n-cube. In other words, players agree that if 
after the hats are placed, they are "on" an edge, then they will guess as if the actual hat placement 
corresponds to the vertex pointed to by the arrow on that edge in the agreed-upon strategy. For 
example the edge 10010 —?■ 11010 corresponds to the situation when the second player sees 1, 0, 1 
and on the first, third, fourth and fifth players respectively. The orientation of the edge indicates 
that the second player will predict that her hat color is 1. 

If the hat placement corresponds to a vertex v, then the number of correct guesses is the in- 
degree of v. So Iwasawa's problem of finding strategies that guarantee that either a answers 
are correct or b answers are correct is equivalent to the problem of finding an orientation of the 
hypercube where each vertex has in-degree either equal to a or to b. 

For example, consider the special case mentioned above: a = and b = n, i.e., where the goal is 
that everyone guesses right or everyone guesses wrong. In this case there is an easy "checkerboard" 
winning strategy based on the fact that the hypercube is a bipartite graph. If f is a bit string 
uit;2 . . . Vn, Vi G {0, 1}, then let P{v) G {0, 1} be the parity of the sum of the bits, i.e., P{v) := 
vi + ■ ■ ■ + Vn mod 2. All edges connect vertices of opposite parity. So one winning strategy is to 
orient every edge towards, say, its endpoint with even parity. The reader might enjoy showing that 
this strategy is essentially unique. 

In the sequel a, 6, n, and P{v) will be as above. We let [a, fe]„ be shorthand for the problem of 
realizing an orientation on the n-cube whose only in-degrees are a and b. If there are s vertices with 
in-degree a and t vertices with in-degree b then the equations above, s + t = 2", and as + bt = n2'^~^, 
must obviously hold. Our main theorem says that these necessary conditions for the existence of 
the desired orientation are also sufficient. 

Theorem 1. If n is a positive integer, and a and b are between and n, then there is an orientation 
realizing [a, 6]„ if and only if there are non-negative integers s and t so that s + t = 2" and 
as + bt = n2'^-^ . 

The case in which n is even and a or 6 is n/2 is easy to work out (every vertex will have in-degree 
n/2, and an orientation can be obtained by orienting an Eulerian tour on the n-cube), and it is 
easy to verify that this means that a = 6 or that one of s,t is zero. We regard this case as settled 
and from now on take s and t to be positive, and a < b. 



2 Reduction to primitive orientations 

Solving the equations s + t = 2^ and as + bt = n2'^~^ for s and t gives 



and 



t 



(1) 



From this we see that a < n/2 < b (also obvious by interpreting the equations as implying that the 
average in-degree has to be n/2). 

The first few possible cases are tabulated below. 



n = l 


[0,l]i 


n = 2 


[0,2]2 


n = 3 


[0, 2 3, 0, 83, 1, 2]3, 1, 3J3 


n = 4 


[0, 4]4, [1, 3]4 


n = 5 


[0, 4]5, [0, 5]5, [1, 3]5, [1, 4]5, [1, 5]5, [2, 3)5, [2, 4]5 


n = 6 


[0, 4]6, [0, 6], [1, 5]6, [2, 4]6, [2, 6]6 


n = 7 


[0,4]7, [0,7]7, [1,5]7, [1,6]7, [2,4]7, [2,5]7, [2,6]7, [3, 4)7, [3, 


5]7, [3,7]7 


n = 8 


[0,8]8, [1,5]8, [1,7]8, [2,6]8, [3,5]8, [3,7]8 



The number of possible pairs of in-degrees for the n-cube grows large with n, for instance when 
n = 1000 there are 3038 possible pairs of in-degrees that satisfy the necessary conditions. 

The following theorem will allow us to reduce the number of cases that need to be considered 
explicitly by giving useful reductions. 

Theorem 2. The following hold: 

(a) [a, b]n is realizable if and only if [n — b,n — a]n is realizable; 

(h) [a, n — a\n is realizable for all < a < n; 

(c) if [a, h]n is realizable then [a + 1, 6 + l]n+2 is realizable; and 

(d) if [a^b]n is realizable then [ka^kb]]^^ is realizable. 

Proof. For part (a) we simply note that if we have an orientation for [a, 6]„ then reversing all the 
edges gives an orientation for [n — 6, n — a]„ and vice versa. 

For part (b) we produce an orientation by generalizing the [0, n]„ strategy given above. An 
edge joins vertices v and v' with P{v) = and P{v') = 1, and v' is obtained from v by flipping the 
i-th coordinate for some i. We orient the edge towards v \il < i < a and towards v' \i a < i < n. 
One checks that the in-degree of a vertex with P{v) = is a, and is otherwise n — a. 

For part (c) we note that the (n + 2)-cube is the product of the n-cube with the four cycle (or 
2-cube). Orient each copy of the n-cube as dictated by the orientation [a, 6]„. The remain edges 
are a disjoint union of four-cycles and we orient each of those in (some) cyclic order. At each vertex 
we have either a or 6 in-edges coming from the n-cube and 1 in-edge from the four cycle, i.e., we 
have a solution to [a + 1, 6 -|- l]n+2- 

Finally for part (d) suppose that we have an orientation for [a, 6]„. Write vertices of the fcn-cube 
in the form 

V = W1W2 ...Wn 



where each Wi is a vertex of the fc-cube. Define a map ^ from vertices of the fen-cube to vertices 
of the n-cube by ^(v) = P{'Wi)P{w2) ■ ■ ■ P{wn)- Note that if u and w are adjacent in the fen- 
cube then ^(u) and ^{w) are adjacent in the n-cube (in both cases they wih differ in exactly one 
entry). Orient the edge between u and w according to the orientation between ^(n) and ^{w). It 
is easy to check that each in-edge at a vertex in the n-cube gets hfted to exactly fe in-edges to a 
corresponding vertex in the fen-cube. So if the in-degrees were originally a and b they become ka 
and kb, as desired. D 

From Theorem [2] we see once we have an orientation [a, 6]„ that we immediately get many 
orientations, i.e., [a + 1, 6 + l]„+2, [a + 2, 6 + 2]„+4, [2a, 26]2„, [3a, 36]3„, [3a + 1, 36 + l]3n+2, and 
so on. With a little work it is easy to tabulate the first few cases that do not seem to be reducible 
any further; the first few are 



[0,l]i, [1,3]3, [1,5]5, [3,7]7, [1,9]9, [3,ll]ii, [5,13]i3, [7,15] 



15- 



This appears to indicate that for each odd n there is a unique a < n/2 such that [a, n]„ is not 
reducible using any of the results in Theorem [21 and that a can be obtained from n by removing 
the most significant bit in its binary expansion. This is the content of the following Corollary 

Corollary 1. It suffices to prove Theorem Ul for [a,n\n for odd n where 2 < n < 2^^ and 
a = n — 2^ . 

We will say that orientations as in the corollary are primitive, i.e., orientations [a,n]„ where n 
is odd, a < 2 < n, and a + 2 = n. Vertices with in-degree equal to n will be said to be sinks. 

Proof or Corollary m We only need to show how any [a, b]n can be derived from a primitive orien- 
tation. 

First we note that the result already holds for a + 6 = n by part (b) of Theorem [2l and so 
without loss of generality we may assume that a + 6 > n (if not reverse the orientation by part (a) 
of the Theorem). 

II b < n then by part (c) of Theorem [2] we have [a, 6]„ can be found using [a — l,b — l]n-2- 
Repeating this we see that it suffices to produce orientations for cubes when b = n. Now by part 
(d) of Theorem [2] if [a,n]„ has gcd(a,n) > 1 then we can divide out by the gcd. Therefore, it 
suffices to consider orientations [a,n]„ with gcd(a, n) = 1. (By using the equations ([I]) we note 
that in both methods of reduction that if s and t were positive integers for [a, 6]„ then they also 
are positive integers for [a',6']„/.) 

Let q denote the odd part of n — a. Then examining the equations ([T|) we must have that q I n 
and q\{n — 2a) but this implies that q | gcd(a, n) = 1. Therefore we can conclude that n — a = 2 
or a = n — 2^ for some fc. This implies that a and n are odd (by their coprimality) , and the fact 
that s and t are positive imply that a < n/2 so that the orientation is primitive, as desired. D 

3 Using thickened Hamming balls 

To find primitive orientations, we will use perfect single error-correcting Hamming codes (see, e.g., 
[2]). They exist when the dimension is one less than a power of two: if n = 2 — 1 then there is a 
subset H of the vertices of the n-cube such that every vertex is either in H, or adjacent to a unique 



element of H. In the terminology of error-correcting codes, the Hamming balls of radius 1 centered 
at elements of H are disjoint, and cover the n-cube. 

An orientation for [a, n]„ when n = 2^ — 1, a = n — 2^^^ = {n — l)/2 is easy to describe using 
such an H. Indeed, we let all elements of a Hamming code H be sinks. Each vertex not in H is 
incident to exactly one edge in H, and it must be oriented towards the sink. If we erase the sinks 
and the edges incident to them, we have a graph where every vertex has degree n — 1 = 2^^ — 2. 
Since every vertex has even degree we can find an Eulerian tour (or union thereof). If we orient 
those edges as we traverse those tours we get a directed graph where each vertex has in-degree 
(and out-degree) equal to (re — l)/2 = a which, when combined with the vertices in H and edges 
incident on those vertices, gives the desired orientation. 

To construct primitive orientations more generally, it is convenient to introduce some notation. 
If u is a bit vector then let v{i) denote the vector obtained from v by flipping bit i, let v{i,j) be 
shorthand for {v{i)){j), and similarly for more flipped bits. 

li H is a Hamming code in an n-cube, n = 2 — 1, then every vertex is either an element of H, 
or is of the form h{i) for a unique h in H, and a unique coordinate i, 1 < i < n. The following 
result will play a key role in the proof of Theorem [H 

Lemma 1. Let H be a Hamming code in the n-cube, n = 2^ — 1. Fix i, 1 < i < n, and h in H . 
Then the function 

fU) — ^^6 unique k such that h{i,j) = h'{k) for some h' & H 

is a permutation of {1, ... ,n}, with i as a fixed point. 

Proof. From the definition, f(i) = i. li j ^ i then h{i,j) is outside the Hamming ball of radius 1 
centered at h, and is not in H (since the point h{i) lies in the Hamming balls centered at h and 
h{i,j)). Therefore there are unique h' G H and k such that h' ^ h and h{i,j) = h'{k). Moreover, 
k y^ i since this would imply that h{j) = h' . 

Suppose that h{i,ji) = hi{k) and h{i,J2) = h2{k). Then 

hi{J2) = h{i,ji,J2,k) = h2{ji). 

By the defining properties of Hamming codes, this is possible only if j'l = J2 and hi = h2, finishing 
the proof of the Lemma. D 

Now we construct a primitive orientation [a, n]^. The key idea is to "thicken" Hamming balls 
coming from smaller dimensions. Choose k such that 2^ < n < 2^^^ , so that re = a -|- 2^^. Let 
a = 2m — 1, and hq = 2 — 1. Choose a Hamming code H on the reo-cube. Write vertices of the 
re-cube in the form 

{p,v) 

where p is on the 27re-cube and v is on the reo cube; note that 27re-|-reo = o-|-2 = re. To describe the 
desired orientation we proceed as above by specifying the sinks, noting which edges have orientations 
forced by the location of the sinks, and then finding the remaining edge orientations by noting the 
existence of suitable Euler tours (see Figure [I]) . 

Vertices {p,v) on the re-cube are either even, which is equivalent to P{p) = P{v), or odd, which 
is equivalent to P{p) ^ Piv). In addition, we say that a vertex {p,v) is an //-vertex if v is in H, a 
low vertex ii v = h{i) for h G H and 1 < i < a, and a high vertex if t; = h{i) for a < i < uq. Thus 



H^ 
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H~ 
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Low ^" ^ Low 

Step 1: Place the sinks. 



H+ t 



High+ 



Low+ Low 

Step 2: Add forced edges. 




H+ t 
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Low+ < 




> Low 



Step 3: Use Euler cycles. 
Figure 1: The steps used to create the orientation for primitive [o, n]„. 

there are three kinds of even vertices, which we will denote H^ , Low^, and High^, and three kinds 
of odd vertices, written H~ , Low", and High^. 

The sinks of our orientation will be the union of the H^and High^ vertices. (Note that there 
are no edges between these vertices.) All edges incident on these vertices are of course oriented 
towards them, and they have in-degree n. 

Let {p,h) be an H~ vertex. Then {p,h) is adjacent to 2m of the H^ vertices (flip a bit of p). 
In addition, (p, h) is adjacent to a vertices of type Low"*", and a' := hq — a vertices of type High"'". 
The vertices to sinks are forced, and since the in-degree of {p, h) must be a we conclude that all a 
edges going from a Low"*" vertex to {p, h) are oriented towards {p, h). 

Now let {p,h{i)) be a High" vertex. Then (p,h{i)) is adjacent to a single H~ vertex (namely 
{p,h)) and 2m of the High"^ vertices of the form {p{j),h{i)). By the above lemma there are an 
additional no — 1 neighbors of the form {p, h' {(.)) of which a of these are Low"*" vertices and riQ — l — a 
are High "'"vertices. The vertices to sinks are forced, and since the in-degree of {p,h{i)) must be a 
we conclude that all a edges going from a Low"*" vertex to (p, h{i)) are oriented towards {p, h{i)). 

Now consider the undirected subgraph of the n-cube obtained by removing all edges whose 
orientation has already been determined. The only remaining edges are those which connect Low"*" 
and Low" vertices. Suppose that {p,h{i)) is a Low"*" vertex. Then it will be adjacent to a of the 
Low" vertices of the form {p{j),h{i)) and by the lemma it will be adjacent to another a of the 
Low" vertices of the form (p, h'{i)). A similar thing happens for the Low" vertices. In particular, 
in this undirected subgraph the non-isolated vertices all have degree 2a. Therefore by taking Euler 
cycle(s) we can direct these edges in the hypercube so that the in-degree of the Low"*" and Low" 
vertices are all o. We have oriented the n-cube, using only in-degrees n and a, as desired. This 
finishes the proof of Theorem [H 

To see a simple example of this constructed orientation we consider the [1,5] 5 case, built by 
thickening the Hamming balls centered at 000 and 111 in the 3-cube. This is illustrated in Figure [2] 
(the sources are boxed and for simplicity we do not draw every possible edge). In Figure [3] we only 
give the in-degree 1 vertices where we have added in all of the forced orientations, the remaining 
edges are easily oriented to give in-degree 1 on all vertices. 

4 Concluding remarks 

We have looked at the problem of orienting the edges of the n-cube so that we have only two 
different in-degrees. Our main result is that obvious necessary conditions from counting vertices 
and degrees are also sufficient. In our construction we relied heavily on Hamming codes and so 
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Figure 2: The thickened Hamming balls for the [1, 5]5 case. 
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Figure 3: The in-degree 1 vertices for the [1,5]5 case. 

this argument does not extend to general graphs. Neither does the result: consider the graph in 
Figure m which has 8 vertices and is regular of degree 3. Then having four vertices with in-degree 
3 and four vertices with in-degree satisfies the necessary conditions but it is easy to see that this 
is impossible and so it is not sufficient. It would be interesting to know if there were any other 
general class of graphs for which the necessary conditions are also sufficient. 




Figure 4: An example of a graph where the necessary conditions are not sufficient. 

A natural generalization of the problem that we have considered is to show that we can orient 
the edges of the n-cube so that there are Si edges of in-degree Oj for i = 1, . . . , A; if and only if 
si + • • • + s/c = 2*^ and oisi + • • • + a^Sk = n'2P'~^ . While our result shows this is true for k = 2, 
this is false for fc = 3. For example there is no way to orient the 4-cube so that there are 7 vertices 
with in-degree 0, 2 vertices with in-degree 2, and 7 vertices with in-degree 4. 

One way to see this is to note that there is essentially only one way to pick seven vertices with 
in-degree 4, i.e., picking vertices with Hamming weight and 2. This leaves only 4 edges in the 
4-cube unoriented, namely the ones incident to the vertex with Hamming weight 4 and there is no 



way to orient these 4 edges to get 2 vertices with in-degree 2. 

Another generahzation is to increase the number of different colors of hats, i.e., to have k 
different colors of hats. This also has an interpretation graphically as a marking of an n-dimensional 
hyper-hypercube. We let the vertices correspond to the k"" possible placements of hats on the 
players, edges again will consist of the possible nk'^~^ situations that a player can be in. For 
instance if A: = 3 and n = 5 then the edge {21001,21011,21021}, also denoted 210*1 where the * 
entry permutes through all possibilities, corresponds to the situation when the designated fourth 
player sees 2, 1, and 1 on the designated first, second, third and fifth players. To record the 
strategy in this situation we simply mark the vertex in the edge that corresponds to the guess 
the player will make. Finally, observe that the number of correct guesses for a placement of hats 
corresponds to the number of times the corresponding vertex has been marked among all edges. 
(The case k = 2 reduces to what we previously considered where we mark the terminal vertex on 
each edge.) 

In particular, a strategy that will produce either a or b correct guesses for any arbitrary place- 
ment of hats corresponds to marking the edges of the n-dimensional hyper-hypercube so that each 
vertex is marked either a or 6 times. If we have s vertices marked a times and t vertices marked b 
times then we again have the obvious necessary condition that s + t = k" and that as + bt = nk'^~^. 

Part of the difficulty of this variation is that some of our tools generalize while others do not. 
For example, we can no longer "reverse the orientation". However, some reductions still work. As 
before let [a, 6]„ denote the problem of realizing a marking of the n-dimensional hyper-hypercube 
so each vertex is marked either a or b times. 

Theorem 3. Given that we are working over a k-letter alphabet then 

(a) If [a, b]n is realizable then [o + 1, 6 + l]n+k is realizable; and 

(b) if[a,b]n is realizable then [£a,ib]en is realizable. 

The proofs are similar to the ones in Theorem [3l Using Theorem [3] we can as before reduce to 
primitive orientations, the first few of which are listed below for k = 3,4, 5, 6, 7. 



k = 3 


[0,l]i, [0,1]2, [0,3]4, [1,4]4, [0,3]5, [1,4]5, [0,3]7, [1,7]7, [0,3]8 


k = A 


0,li, [0,l2, 0,l3, [0,23, 0,25, [0,45, [1,35, 1,55, [1,56 


k = 5 


0,li, [0,l2, 0,l3, [0,l4, 0,56, [1,66, [0,57, 1,67, [0,58, 


[1,6 8 


k = 6 


0,li, [0,1 2, 0,13, [0,23, 0,14, [0,34, [0,15, 0,25, [0,35, 


[0,45 


k = 7 


0,li, [0,l2, 0,13, 0,14, 0,15, 0,l6, 0,78, 1,88, 0,79, 


[1,89 



A few of these are easy to check by hand (i.e., [0, l]i and [0, 1J2 for k = 3). By translating 
the problem of finding a marking into a SAT problem and then testing if the resulting expressions 
were satisfiable, we were also able to find markings for [0, 3)4 and [1, 4]4 for k = 3 and for [0, 2]3 for 
k = A. For the [0, 3]4 case there are 81 vertices, 36 are marked 3 times each and 45 are not marked 
at all. Listed below is one way to mark the vertices with the edges to achieve [0, 3J4 for /c = 3, we 
have only listed the vertices which get marked and indicated which edges mark them by using *s, 

i.e., 2022 indicates that 2022 is marked by the edges *022, 2*22 and 202*. 

0000, 0002, 0010, 0021, 0101, 0111, 0112, 0120, 0122, 0200, 0212, 0221, 












1001, 1012, 1020, 1021, 1102, 1110, 1111, 1122, 1200, 1211, 1222, 2002, 
2011, 2012, 2020, 2022, 2100, 2102, 2111, 2121, 2201, 2202, 2210, 2220. 



It may well be true that the corresponding statement of Theorem [T] holds for all values of k (in 
which case Theorem [1] reduces to the k = 2 case) . For values of /c > 3 it will require some new 
ideas and approaches to establish the result or to search for counterexamples. 
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